package com.library.books.domain;

import com.baomidou.mybatisplus.annotation.FieldFill;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.fasterxml.jackson.annotation.JsonFormat;
import com.library.common.annotation.Excel;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.experimental.Accessors;

import java.io.Serializable;
import java.math.BigDecimal;
import java.util.Date;

/**
 * 借阅对象 books_borrow
 *
 * @author hb
 * @date 2024-10-14
 */
@ApiModel("借阅对象 表名：books_borrow")
@Accessors(chain = true)
@Data
@NoArgsConstructor
@AllArgsConstructor
public class BooksBorrow implements Serializable {
    private static final long serialVersionUID = 1L;

    /** id */
    @ApiModelProperty("id")
    @TableId(type = IdType.AUTO)
    private Long borrowId;

    /** 书籍副本id */
    @ApiModelProperty("书籍副本id")
    @Excel(name = "书籍副本id")
    private Long booksCopyId;

    /** 借阅人卡号 */
    @ApiModelProperty("借阅人卡号")
    @Excel(name = "借阅人卡号")
    private String borrowCard;

    /** 借阅天数 */
    @ApiModelProperty("借阅天数")
    @Excel(name = "借阅天数")
    private Integer borrowDays;

    /** 续借天数 */
    @ApiModelProperty("续借天数")
    @Excel(name = "续借天数")
    private Integer borrowRenewDays;

    /** 续借时间 */
    @ApiModelProperty("续借时间")
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @Excel(name = "续借时间", width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss")
    private Date borrowRenewTime;

    /** 归还时间 */
    @ApiModelProperty("归还时间")
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @Excel(name = "归还时间", width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss")
    private Date borrowReturnTime;

    /** 应还时间 */
    @ApiModelProperty("应还时间")
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @Excel(name = "应还时间", width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss")
    private Date borrowShouldReturnTime;

    /** 借阅状态：0：正常，1：逾期，2：已归还 */
    @ApiModelProperty("借阅状态")
    @Excel(name = "借阅状态" , dictType = "borrow_status")
    private String borrowStatus;

    /** 学生编号 */
    @ApiModelProperty("学生编号")
    @Excel(name = "学生编号")
    @TableField(fill = FieldFill.INSERT)
    private String studentNumber;

    /** 创建人id */
    @ApiModelProperty("创建人id")
    @Excel(name = "创建人id")
    @TableField(fill = FieldFill.INSERT)
    private Long createId;

    /** 创建者 */
    @ApiModelProperty("创建者")
    @Excel(name = "创建者")
    @TableField(fill = FieldFill.INSERT)
    private String createBy;

    /** 创建时间 */
    @ApiModelProperty("创建时间")
    @Excel(name = "创建时间")
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @TableField(fill = FieldFill.INSERT)
    private Date createTime;

    /** 修改人id */
    @ApiModelProperty("修改人id")
    @Excel(name = "修改人id")
    @TableField(fill = FieldFill.UPDATE)
    private Long updateId;

    /** 修改人 */
    @ApiModelProperty("修改人")
    @Excel(name = "修改人")
    @TableField(fill = FieldFill.UPDATE)
    private String updateBy;

    /** 更新时间 */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @TableField(fill = FieldFill.UPDATE)
    private Date updateTime;

}
